//定制请求实例
//导入axios
import axios from "axios";
import { ElMessage } from 'element-plus'

//定义一个变量，记录公共前缀
// const baseURL='http://localhost:8080';
const baseURL='/api';
const instance = axios.create({baseURL});
import {useTokenStore} from '@/stores/token.js'

//添加请求拦截器
instance.interceptors.request.use(
    (config)=> {
        //请求前的回调
        //添加token
        const tokenStore = useTokenStore();
        //判断有没有token
        if(tokenStore.token){
            config.headers.Authorization = tokenStore.token
        }
        return config;
    },
    (err)=>{
        //请求失败的回调
        Promise.reject(err)
    },
    {
        persist: true
    }

)
import  {useRouter} from "vue-router";
const router = useRouter();
//添加响应拦截器
instance.interceptors.response.use(
    result => {
        //如果业务状态码为0，代表本次操作成功
        if (result.data.code == 0) {
            return result.data;
        }
        //代码走到这里，代表业务状态码不是0，本次操作失败
        ElMessage.error(result.data.message || '服务异常');
        return Promise.reject(result.data);//异步的状态转化成失败的状态
    },
    err => {
        //如果响应状态码时401，代表未登录，给出对应的提示，并跳转到登录页
        if(err.response.status===401){
            ElMessage.error('请先登录！')
            router.push('/login')
        }else{
            ElMessage.error('服务异常');
        }
        return Promise.reject(err);//异步的状态转化成失败的状态
    }
)





//将实例暴露在外面
export default instance;
